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очевидные мысли 


Кажется, мы всё ещё не умеем писать хороший код 
Кажется, мы не знаем, что это такое 

Определённо, хороший кол! = плохой код 
Определённо, если не трогать код, то как будто и 
наплевать на него 

А вотесли начать с ним работать... 


Код надо писать так, 


как если поддерживать 
его будет эмоционально- 
неустойчивый человек 

с мачете, который знает, 
гле вы живёте. 


ч 
Плохой Код 
У пи /Озегз//.1езпспем/Рир{югтРго]ес{$/зКе!етоп/згс 6 1!ез 


ы пи Соггойег 1 1е 
(©) РооСогигойег.рпр 


У № ОТО 1 Не 


Классический пример © © зотеГоо.р!р 
Новая фича У ви Керо$Когу 2 Ше$ 
© РооВерозКогу.рпр 


@® РооВерозКогуй\{егасе.рпр 


У Ви Зегмсе 2 Нез 
© Рообегмсе.рйр 
® Рообегмсейщекасе.рпр 


р 6.2 баачеа 


Соттй Ме$з$аде 
дефт5отеРоо [Е00-1] 


|| Л ОХО и КОД У 54 1 /9зегз/./езпспеу/РирзогтРго]ес{$/Ке!е{оп/згс 6 е$ 


пи Сопгойег 1 1е 

(© РооСогигойег.рпр 
Ви ОТО 1 Не 
Добавили немношк © Апо!пегРоо.рпр 

пи ВерозКогу 2 ез 

(©) РооВерозКогу.рйр 

@® РооВерозКогуи{еасе.рНр 
Ви Зегмсе 2 Нез 

© Рообегмсе.рпр 

® Рообегусе!\{еКасе.рпр 
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р 6.2 1аааеяд 5 тоамеа 


Соттй Ме$заде 


детАпо{ПегРоо [Е00-2] 


ъ 
| Л] ОХхО й КОД и пи /зегз/.1езпспем/Рир${огтРго]ес{$/$Ке|етоп/згс 6 !ез 


У пи СогитоПег 1 1е 
(© ВагСопигоег.рЮр 

у Я шото 1не 
© ЗотеВаг.рНр 

Друга я Ф ина У пи ВерозКогу 2 1 1ез 

(© ВагКеро$Когу.рпр 
®) ВагВерозКогуи{еКасе.рпр 

У Ви Зегмсе 2 Нез 
©) ВагЗегмсе.рпр 

@®) ВагЗегмсей\{е[асе.рпр 


Р 6.2 баааеа 


Соттй Ме$$аде 


де*5отеВаг [Ваг-1] 


Плохой код Ета т 


Мегата Бгапсй Бг1 и\о Бгапср тат 


Мате Уоцг$ (та... ТПейз (6... Ас 


Параллельная ЕооСоп!гоег.рнр -/РнрэюгтРк Моде _ Моатед ПИЯ 


разра ботка. © РооВерозКогу.рпр -/РИрз1огтР! МодМеа — Моамеа 
@® РооВерозКогунеГасе.рпр -/РН Моа#еа Моамеча |на 
© Рообегмсе.рпр -/Рирэ{огтРгое МодМеяа — Моамеа 
® Рообегмсен\е"асе.рйр -/РНр$1 Мод®еа Моашеа 


Не самый плохой 
случай! 


Плохой код 


Конфликтов слияния нет, но лучше бы они были. 
е ||ОотТеряли изе 


г Задублировали че 


Плохой код 


р = ——— 


т 


в инннннный 


Плохой код 


Плохой код 


типа функция(ввод) 

получили данныеа 

отвалидированили а 

получили данные 6 

отвалидировали 6 // где-то тут положили 6 в статическое поле статического класса 
отвалидировалиаи © 

сконвертировали данные вс 


отвалидировалиаис 


обработали % // где-то тут взяли из статического поля статического. класса 
вызвали метод, который вызывает метод, который == = ® 6, СФ > Фи © 


вывод 


Плохой код 


Даже маленькие правки затрагивают много файлов 
И разных директорий 

Непонятная структура 

Конфликты 


Сложно понимать 
Сложно изменять 
Сложно удалять 


Хороший ход 


. Декомпозиция 


: Сохранение единой ответственности 


Хороший ход 


. С декомпозицией понятно, а что с композицией? 


° ЛПанные + код = объект 


ООГ 


Принципы Алана кКея 
’ Всё есть объект 


. Объекты общаются сообщениями 


се есть 
объект 


Все есть 


Фича — это объект 


 Фича попадает под квантор «всё» 


’ Фича — композиция данных и обрабатывающего их кода 
’ Фича общается сообщениями настоящим, 
а не вырожденным образом 


Фича — это объект 


Приложение 


Фича — это объект 


Группировка по фиче — проще понимать, 
проще удалять, проще извлекать в микросервис 


Инкапсуляция внутри фичи 


СОК$ — это база, не общаемся сущностями, а только 
сообщениями 


Сообщения команды, сообщен ия уведомления, сообщен ия 
статусы 


ЪИнкапсуляция 


#[ОЮМ\Со\итп(+уре: '$4г1пд', Тепдтн: 255)] 67 67 #ОЮМ\Сотитп (+уре: '$%г1п9', Тепдфн: 255)] 
| роБл4с гла фе; 
69 


79 


79 


инкапсуляция 


Бизнес сущность полностью скрыта внутри фичи 


Механизма приватгов и пабликов не хватает, 
их никогда не хватало 


Нужн р срагинческие анпализатовьь всегда были Нужны 


Можно избавиться от бесполезных приватгов в 
сущности и тестов на примигивныЫе сеттеры/геттеры 


Обработка команд 


’ Отправка и обработка сообщения команды — 
единственный способ взаимодействовать 
на бизнес сущность 


° Строго по сценарию — валидация, блокировка, 
действие, сохранение, разблоки ровВка, уведомления 


’ Одна команда — один обработчик 


Обработка команд 


руб11с Фипсф1оп __1пуоКе(СоттапЯ $соттапа) + 


’ Меньше кода 
$401$->\а11д9афог->\уа11да*е ($соттапа) ; 


. Лучше композиция $411$->Тоскег->Тоск ($соттапа) ; 
$401$->Папа\е ($соттапа) ; 
. Проще ревью $411$->Тоскег->ипТоск ($соттапа) ; 
} 
И 


ргофесфеч Рипсф1оп Папд\Те(СоттапЯ $соттапа) 
$Роо = $4161$->геро$1Фогу->деЕ5отеРоо(); 
И. 
$411$->геро$1%огу->Е1и$п (); 

} 


Жизнь сообщения 


руб\1с Ропсф1оп __1пуоке(Соттапа $соттапа) + 


Или ещё проще. $Роо = $411$->геро$1%огу->9е*$отеРоо(); 
ИГ. . +. 


} 


изн Б сооб щен ия СТа$$ ЗотеКеаЧОотО {+ 


руб\1с Фопсф1оп __сопзгос* ( 


оБТ1с 1пе $19, 
В большинстве случаев 2 } 


руб\1с $%г1тд $41Ще, 
объекты сообщения 


руб11с $+г1тпд $Боду, 


достаточно хороши, как руб\1с 1п* $+1тезтатр, 
контракты, чтобы просто ) { 
делать вот так. } 

} 


$Чафа = пем ботеВеаЧч0оТО(...$гом); 


$] з0п = 75$0п_епсоде($да*а); 


Жизнь сообщения 


Или так. 
#[Воуфе(рафв: '/4{19}', пате: 'ирда*е', 


геди1гетеп+$: ['19' => "\д+"], тефвод$: ['РУТ'])] 
руб11с Фипсф1оп ирдафе(1те $1а, Кедиез$* $гедиуе$+): . 
г 

$Чафа = ['1494' => $19] + $гедуе$+->+оАггау(); 

$401$->6и$->915$ра%+сп (пем Соттапа(...$9афа)); 


гефигп $401$->)50п(['з$0ссез$$' => +гие]); 


Итого 


Фичи — полноценные объекты с инкапсуляцией и 
интерфейсами-сценариями 


Фичи общаются сообщениями, которые суть контракты и 
определяют границы декомпозиции 


Инкапсуляция и сокрытие внутри фичи требует свежего 
взгляда и отдельных инструментов 


выполняем 


Фича 
Сценарий 
Сообщение 
Аспект 


Цикл разработки 


Фича 
Сценарий 
Сообщение 
Аспект 


Цикл разработки 


Не выполняем 


Фича 
Сценарий 
Сообщение 


Аспект 


Цикл разработки 


Цикл разработки 
Пишем тесты 
(Не) меняем реализацию 
Собираем статистику и добавляем метрики 


А/В тесты, фича тогглы и вот это вот всё 


Цикл разработки 


Е1па\т с1а$$ Зегутсе 


ы 


руб11с Фипсф1топ 90()+{ } 

руб11с ФипсЕ1оп доРасаде!по(){ } 
руб\1с ФипсЕ1оп доРасаде0ио$()+{ } 
рг1\уафе РипсЕ1оп 1пегпа\Ипо()+ } 
рг1\уафе ФипсЕ1оп 1пфегпа10ио$()+{ } 
рг1\уафе ФипсЕ1оп 1пфегпа1Тге$()+{ } 


Цикл разработки 


Е1па\т с1а$$ Зегутсе 


{ 


руб11с Рипс1оп 90()+4 } 

руб\1с Рипс1оп доРасаде!по()+{ } 
руб11с РипсЕ1оп ЧоРасадедио$()+ } влезть 
рг1\уафе ФипсЕ1оп 1пфегпа\Ипо(){ 


влезть 
. $ . сюда 
рг1уафе РипсЕ1оп мое Е 
сюда 


рг1\уафе ФипсЕ1оп 1пфегпа\1Тге$(){ 


Цикл разработки 


Е1па\т с1а$$ Зегутсе 


ы 


руб11с Фипсф1топ 90()+{ } 

руб11с ФипсЕ1оп доРасаде!по(){ } 
руб\1с ФипсЕ1оп доРасаде0ио$()+{ } 
рг1\уафе РипсЕ1оп 1пегпа\Ипо()+ } 
рг1\уафе ФипсЕ1оп 1пфегпа10ио$()+{ } 
рг1\уафе ФипсЕ1оп 1пфегпа1Тге$()+{ } 


Цикл разработки 


сТаз$$ Зегутсе 


4 


руб\1с ФопсЕТоп 90()+ } 

руб11с Фипс1оп доРасаде/по()+{ } 
руб11с ФипсЕ1оп доРасаЧде)ио$()+{ } 
рго+есфед Рипс1оп 1птегпа\Ипо()+{ } 
ргофесфед ФипсЕ1оп 1пфегпа10ио$()+{ } 
рго+есеч ФипсЕ1оп 1п{егпа1Тге$()+{ } 


т 


хорошего 
кода 


[Оценивайте доклад и 


|задаваите вопросьй 
7 


/ 


и 
и’ РР’ РР Кизза 
и У’ | 2022 


д" 


| 


